<template>
	<view class="content">
		<view class="row b-b">
			<text class="tit">联系人</text>
			<input class="input" type="text" v-model="addressData.name" placeholder="收货人姓名" placeholder-class="placeholder" />
		</view>
		<view class="row b-b">
			<text class="tit">手机号</text>
			<input class="input" type="number" v-model="addressData.mobile" placeholder="收货人手机号码" maxlength="11" placeholder-class="placeholder" />
		</view>
		<view class="row b-b">
			<text class="tit">地址</text>
			<text @click="chooseLocation" class="input">
				{{addressData.addressName}}
			</text>
			<text class="yticon icon-shouhuodizhi"></text>
		</view>
		<view class="row b-b"> 
			<text class="tit">门牌号</text>
			<input class="input" type="text" v-model="addressData.area" placeholder="楼号、门牌" placeholder-class="placeholder" />
		</view>
		
		<view class="row default-row" v-if="manageType=='edit'">
			<text class="tit">设为默认</text>
			<switch :checked="addressData.default" color="#fa436a" @change="switchChange" />
		</view>
		<button class="add-btn" @click="confirm">提交</button>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				manageType:null,
				addressData: {
					name: '',
					mobile: '',
					addressName: '在地图选择',
					address: '',
					area: '',
					default: false
				}
			}
		},
		onLoad(option){
			let title = '新增收货地址';
			if(option.type==='edit'){
				this.defauleShow=true;
				title = '编辑收货地址'
				let data=JSON.parse(option.data);
				
				this.addressData={
					name:data.aname,
					mobile:data.aphone,
					addressName:data.addressname,
					address:data.addressname,
					area:data.area,
					default:data.amin?true:false,
					aid:data.aid
				}
				// console.log(this.addressData);
				
			}
			this.manageType = option.type;
			uni.setNavigationBarTitle({
				title
			})
		},
		methods: {
			switchChange(e){
				this.addressData.default = e.detail.value;
			},
			
			//地图选择地址
			chooseLocation(){
				uni.chooseLocation({
					success: (data)=> {
						this.addressData.addressName = data.name;
						this.addressData.address = data.name;
					}
				})
			},
			
			//提交
			confirm(){
				
				let data = this.addressData;
				console.log(data);
				
				if(!data.name){
					uni.showToast({
					    title: '请填写收货人姓名',icon:'none'
					});
					return;
				}
				if(!/(^1[3|4|5|7|8|9][0-9]{9}$)/.test(data.mobile)){
					uni.showToast({
					    title: '请输入正确的手机号码',icon:'none'
					});
					return;
				}
				if(!data.address){
					uni.showToast({
					    title: '请在地图选择所在位置',icon:'none'
					});
					return;
				}
				if(!data.area){
					uni.showToast({
					    title: '请填写门牌号信息',icon:'none'
					});
					return;
				}
				
				if(this.manageType=='add'){
					let sendData={
						addressname:data.address,
						area:data.area,
						aphone:data.mobile,
						aname:data.name
					}
					this.$api.addAddress(sendData).then((res)=>{
						if(res.data.stastus==200){
							uni.showToast({
							    title: res.data.msg,
								mask:true
							});
							setTimeout(()=>{
								uni.navigateBack()
							}, 800)
						}
					})
				}
				if(this.manageType=='edit'){
					let sendData={
						addressname:data.address,
						area:data.area,
						aphone:data.mobile,
						aname:data.name,
						aid:data.aid,
						amin:data.default?1:0
					}
					this.$api.updateAddress(sendData).then((res)=>{
						if(res.data.stastus==200){
							uni.showToast({
							    title: res.data.msg,
								mask:true
							});
							setTimeout(()=>{
								uni.navigateBack()
							}, 800)
						}
					})
				}
				
				
				
				
				
			},
		}
	}
</script>

<style lang="scss">
	page{
		background: $page-color-base;
		padding-top: 16upx;
	}

	.row{
		display: flex;
		align-items: center;
		position: relative;
		padding:0 30upx;
		height: 110upx;
		background: #fff;
		
		.tit{
			flex-shrink: 0;
			width: 120upx;
			font-size: 30upx;
			color: $font-color-dark;
		}
		.input{
			flex: 1;
			font-size: 30upx;
			color: $font-color-dark;
		}
		.icon-shouhuodizhi{
			font-size: 36upx;
			color: $font-color-light;
		}
	}
	.default-row{
		margin-top: 16upx;
		.tit{
			flex: 1;
		}
		switch{
			transform: translateX(16upx) scale(.9);
		}
	}
	.add-btn{
		display: flex;
		align-items: center;
		justify-content: center;
		width: 690upx;
		height: 80upx;
		margin: 60upx auto;
		font-size: $font-lg;
		color: #fff;
		background-color: $base-color;
		border-radius: 10upx;
		box-shadow: 1px 2px 5px rgba(219, 63, 96, 0.4);
	}
</style>
